/** * Copyright 2014 SAP AG * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.aim.mainagent.service; import java.io.BufferedReader; import java.io.InputStreamReader; import java.util.List; import org.aim.api.instrumentation.entities.OverheadData; import org.aim.api.instrumentation.entities.OverheadRecord; import org.aim.logging.AIMLogger; import org.aim.logging.AIMLoggerFactory; import org.codehaus.jackson.JsonFactory; import org.codehaus.jackson.map.ObjectMapper; import org.glassfish.grizzly.http.server.Request; import org.glassfish.grizzly.http.server.Response; import org.overhead.OverheadEstimator; /** * Measures probe overhead for given probe. * * @author Alexander Wert * */ public class MeasureOverheadServlet implements Service { private static final AIMLogger LOGGER = AIMLoggerFactory.getLogger(EnableMeasurementServlet.class); @Override public void doService(Request req, Response resp) throws Exception { BufferedReader br = new BufferedReader(new InputStreamReader(req.getInputStream())); String json = ""; if (br != null) { json = br.readLine(); } JsonFactory factory = new JsonFactory(); ObjectMapper mapper = new ObjectMapper(factory); String probeClassName = json; LOGGER.info("Requested overhead measurement for probe {}", probeClassName); OverheadData oData = new OverheadData(); List<OverheadRecord> records = OverheadEstimator.measureOverhead(probeClassName); oData.setoRecords(records); resp.setContentType("application/json"); mapper.writeValue(resp.getOutputStream(), oData); } }